tpm: add macros to enhance TPM commands readability
authorMiquel Raynal <[email protected]>
Tue, 15 May 2018 09:57:09 +0000 (11:57 +0200)
committerTom Rini <[email protected]>
Sat, 26 May 2018 00:12:56 +0000 (20:12 -0400)
TPM commands are much easier to read/write with these macros that will
transform words or integers into byte strings. This way, there is no
need to call pack_byte_string() while all variable length in a command
are known (and at must 4 bytes, which is a lot of them).

Signed-off-by: Miquel Raynal <[email protected]>
Reviewed-by: Simon Glass <[email protected]>
Reviewed-by: Tom Rini <[email protected]>
lib/tpm-utils.h

index bc98d1ef8f75d3a8916bda6940c3a81a4d5e26d6..a9cb7dc7ee5d8edad573e5698ace389f7179fc5e 100644 (file)
 /* Internal error of TPM command library */
 #define TPM_LIB_ERROR ((u32)~0u)
 
+/* To make strings of commands more easily */
+#define __MSB(x) ((x) >> 8)
+#define __LSB(x) ((x) & 0xFF)
+#define tpm_u16(x) __MSB(x), __LSB(x)
+#define tpm_u32(x) tpm_u16((x) >> 16), tpm_u16((x) & 0xFFFF)
+
 /**
  * tpm_open() - Request access to locality 0 for the caller
  *